<template>
	<el-card class="box-card">
		<div slot="header" class="clearfix">
			<span>基本资料</span>
		</div>
		<!-- 表单 -->
		<el-form :model="userForm" :rules="userFormRules" ref="userFormRef" label-width="100px">
			<el-form-item label="登录名称" prop="username">
				<el-input v-model="userForm.username" disabled></el-input>
			</el-form-item>
			<el-form-item label="用户昵称" prop="nickname">
				<el-input v-model="userForm.nickname" minlength="1" maxlength="10"></el-input>
			</el-form-item>
			<el-form-item label="用户邮箱" prop="email">
				<el-input v-model="userForm.email"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" @click="submit">提交修改</el-button>
				<el-button @click="resetForm">重置</el-button>
			</el-form-item>
		</el-form>
	</el-card>
</template>

<script>
	export default {
		name: "UserInfo",
		data() {
			return {
				// 存储表单的数据对象
				userForm: this.$store.state.userInfo,
				// 存储表单验证规则对象
				userFormRules: {
					nickname: [{
							required: true,
							message: '请输入用户昵称',
							trigger: 'blur'
						},
						{
							pattern: /^\S{1,10}$/,
							message: '昵称必须是1-10位的非空字符串',
							trigger: 'blur'
						}
					],
					email: [{
							required: true,
							message: '请输入用户邮箱',
							trigger: 'blur'
						},
						{
							type: 'email',
							message: '邮箱格式不正确',
							trigger: 'blur'
						}
					],
				},
			};
		},
		methods: {
			// 更新用户的基本信息
			submit() {
				// 1. 验证表单的合法性
				this.$refs.userFormRef.validate(async valid => {
					// 2. 验证失败
					if (!valid) return
					// 2. 验证通过，发送请求
					const {
						data: res
					} = await this.$http.put(
						"/my/userinfo",
						this.userForm
					);
					// 2.1发送请求失败，提示用户
					if (res.code !== 0) return this.$message.error(res.message);
					// 2.2 发送请求成功，提示用户
					this.$message.success("修改用户信息成功！");
					// 2.3 更新vuex中的数据
					this.$store.dispatch("initUserInfo");
				})
			},
			// 重置表单的数据
			resetForm() {
				// 每次重置，都把 store 中最新的值取出来，赋值给 userForm
				// this.userForm = this.$store.state.userInfo
				// 因为v-model和userForm是双向绑定，如果直接将vuex中地址给到userForm，那么当表单数据改变就会改变vuex里面的数据
				// 所以可以使用浅拷贝，将vuex里面的数据拷贝到一个新的对象中，这样就不会改变vuex的数据了
				this.userForm = Object.assign({}, this.$store.state.userInfo);

			}
		}
	};
</script>

<style lang="less" scoped>
	.el-form {
		width: 500px;
	}
</style>
